<!DOCTYPE html>
<html>
  
<head><meta name="generator" content="Hexo 3.8.0">
  <meta charset="utf-8">
  <meta name="author" content="Amos Zhu">
  
  
  <title>Redis教程（三）——Redis的主从复制 | Amos的技术博客</title>

  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

  
    <meta name="keywords" content="redis,centos7,redis,">
  

  
  <meta name="description" content="上篇博文我们了解该如何实现Redis的持久化，这篇博文再get下Redis的主从复制的相关知识点，理解主从复制的操作、原理以及完全重新同步和部分重新同步的区别，能优化主从复制并且进行故障诊断。">

  

  
    <script src="//cdn.jsdelivr.net/npm/leancloud-storage@3.11.1/dist/av-min.js" async></script>
  

  
    <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-MML-AM_CHTML" async></script>
  

  
    <script src="//unpkg.com/valine/dist/Valine.min.js" async></script>
  

  

  <script>
  // theme-ad's config script
  // it can be used in every script
  
  window.AD_CONFIG = {
    leancloud: {"appid":"eObxCkTJ6j4GzRxGLgiHyfJa-gzGzoHsz","appkey":"fzRMAFC6MCE11mp7mnvh4Kwe","comment":true,"count":true},
    welcome: {"enable":true,"interval":30},
    start_time: "2019-05-28",
    passwords: ["efe07af7441da2b69c4a41e42e73be4db47f66010a56900788a458354a7373ec", ],
    is_post: true,
    lock: false,
    author: "Amos Zhu",
    share: {"qq":true,"wechat":true},
    mathjax: true,
    page_type: "",
    root: "/blog/"
  };
</script>

  <script src="/blog/vendor/sha256.min.js"></script>
<script src="/blog/js/auth.js"></script>
<script src="/blog/js/index.js"></script>
<script src="/blog/vendor/qrcode.min.js"></script>

  
    <link rel="icon" href="/blog/images/favicon.ico">
    <link rel="apple-touch-icon" href="/blog/images/touch-icon.png">
  

  <link href="//netdna.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">

  <link rel="stylesheet" href="/blog/css/index.css">
<link rel="stylesheet" href="/blog/styles/components/highlight/highlight.css">

  
</head>
  <body>
    <header class="site-header">
  <div class="site-header-brand">
    
      <span class="site-header-brand-title">
        <a href="/blog/">Amos Zhu</a>
      </span>
    
    
      <span class="site-header-brand-motto"> | 当浮躁的心静不下，不妨写些东西或者看会书</span>
    
  </div>
  <div class="site-header-right">
    <nav class="site-header-navigation">
      
        <a href="/blog/" target="_self">首页</a>
      
        <a href="/blog/archives/" target="_self">归档</a>
      
        <a href="/blog/tags/" target="_self">标签</a>
      
        <a href="/blog/categories/" target="_self">分类</a>
      
        <a href="/blog/redis/" target="_self">redis</a>
      
        <a href="/blog/rabbitMQ/" target="_self">rabbitMQ</a>
      
        <a href="/blog/elasticsearch" target="_self">elasticsearch</a>
      
        <a href="/blog/stuff" target="_self">stuff</a>
      
        <a href="/blog/kafka" target="_self">kafka</a>
      
        <a href="/blog/friends/" target="_self">友链</a>
      
        <a href="/blog/about/" target="_self">关于</a>
      
    </nav>
    <div class="site-header-btn">
      
        <a href="https://gitee.com/amos_zhu" target="_blank" id="site-github">
          <i class="fa fa-github-alt"></i>
        </a>
      
      <a href="javascript:void(0);" id="site-search">
        <i class="fa fa-search"></i>
      </a>
      <a href="javascript:void(0);" id="site-nav-btn">
        <i class="fa fa-ellipsis-v"></i>
      </a>
    </div>
  </div>
</header>
<nav class="table-content" id="site-nav">
  <div class="table-content-title">
    <span>导航</span>
  </div>
  <div class="table-content-main">
    <ol class="toc">
      
        <li class="toc-item">
          <a href="/blog/" target="_self">
            首页
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/archives/" target="_self">
            归档
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/tags/" target="_self">
            标签
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/categories/" target="_self">
            分类
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/redis/" target="_self">
            redis
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/rabbitMQ/" target="_self">
            rabbitMQ
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/elasticsearch" target="_self">
            elasticsearch
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/stuff" target="_self">
            stuff
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/kafka" target="_self">
            kafka
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/friends/" target="_self">
            友链
          </a>
        </li>
      
        <li class="toc-item">
          <a href="/blog/about/" target="_self">
            关于
          </a>
        </li>
      
    </ol>
  </div>
</nav>
<div id="site-process"></div>
    <main>
      
  <div class="passage">
  <div class="passage-meta">
    <span>
      <i class="fa fa-calendar"></i>2019-06-18
    </span>
    
      <span>
        | <a href="/blog/categories/redis/"><i class="fa fa-bookmark"></i>redis</a>
      </span>
    
    
      <span>
        | <i class="fa fa-unlock-alt"></i>UNLOCK
      </span>
    
  </div>
  <h1 class="passage-title">
    Redis教程（三）——Redis的主从复制
  </h1>
  
  <article class="passage-article">
    <p></p>
<h2 id="Redis的安装和持久化"><a href="#Redis的安装和持久化" class="headerlink" title="Redis的安装和持久化"></a>Redis的安装和持久化</h2><ol>
<li><a href="http://amos_zhu.gitee.io/blog/passages/2019-06-13-Redis安装/">Redis的安装</a></li>
<li><a href="http://amos_zhu.gitee.io/blog/passages/Redis的持久化/">Redis的持久化</a></li>
</ol>
<h2 id="Redis的主从复制（replication"><a href="#Redis的主从复制（replication" class="headerlink" title="Redis的主从复制（replication)"></a>Redis的主从复制（replication)</h2><blockquote>
<p>Redis的主从复制是组成Redis高可用的一部分，也是必不可少的一部分，通过Redis提供的复制功能，将数据从Redis（master节点）向另一个Redis（slave节点）复制。<br>我们还是带着问题去整理这个知识点</p>
<ul>
<li>Redis是高可用的一个组成部分，我们为什么需要Redis的主从复制，他有哪些作用</li>
<li>Redis该如何主从复制，需要注意哪些问题</li>
<li>Redis的主从复制原理和机制是怎么样的</li>
<li>Redis的主从复制该如何调优</li>
<li>Redis发生故障时该如何进行故障诊断</li>
</ul>
</blockquote>
<h2 id="准备工作"><a href="#准备工作" class="headerlink" title="准备工作"></a>准备工作</h2><p>主从复制，大多数是为了数据备份、高并发和高可用，而要满足高可用的要求，一般都是两台不同的服务器或者虚拟机节点，以保证主节点服务器宕机或者其他不可知的原因导致服务不能使用，则需要子节点的服务能替代主节点的服务器继续对外提供服务。所以我们先准备两台虚拟机，分别安装redis服务，并且启动服务，其次如果读的QPS比较多的话，一般采用读写分离的模式来分离读数据和写数据（主写从读），通过横向扩容从Redis的实例来扩大读QPS,而实现这一功能，主从复制必不可少</p>
<p>具体安装可以参考上一篇的博文《<a href="http://amos_zhu.gitee.io/blog/passages/2019-06-13-Redis安装/">Redis的安装</a>》<br>我们准备一下两台虚拟机，分别对外提供Redis服务：</p>
<ul>
<li>主节点：192.168.56.105:7000</li>
<li>子节点：192.168.56.106:7000</li>
</ul>
<h2 id="Redis主从复制"><a href="#Redis主从复制" class="headerlink" title="Redis主从复制"></a>Redis主从复制</h2><h3 id="Redis复制的启动"><a href="#Redis复制的启动" class="headerlink" title="Redis复制的启动"></a>Redis复制的启动</h3><p>复制不仅提高了整个redis的容错能力，同时也可以对系统进行横向扩容等，开启子节点复制父节点很容易，有三种方法可以进行复制父节点数据</p>
<ol>
<li><p>redis.conf的配置文件中 添加</p>
<figure class="highlight plain"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td><td class="code"><pre><span class="line">slaveof master_ip master_port</span><br><span class="line">## redis 5.x 版本中</span><br><span class="line">replicaof master_ip master_port</span><br></pre></td></tr></table></figure>
</li>
<li><p>在启动redis的时候，使用命令来启动</p>
<figure class="highlight plain"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">redis-server --slaveof master_ip master_port</span><br></pre></td></tr></table></figure>
</li>
<li><p>在客户端cli中指定主节点</p>
<figure class="highlight plain"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">redis&gt; slaveof master_ip master_port</span><br></pre></td></tr></table></figure>
</li>
</ol>
<h2 id="Redis复制注意事项"><a href="#Redis复制注意事项" class="headerlink" title="Redis复制注意事项"></a>Redis复制注意事项</h2><ol>
<li><strong>将主节点中的<code>protected-mode</code>改为no</strong><blockquote>
<p>如果是保护模式开启，则slave node中 使用 info replication 会发现 master_link_status:down 从而导致复制不成功</p>
</blockquote>
</li>
<li><strong>如果master node中 开启了授权，则在slave node中需要给予主节点的密码 <code>masterauth</code></strong><blockquote>
<p>master node 中<br>requirepass passwd<br>slave node 中<br> masterauth passwd</p>
</blockquote>
</li>
<li>在最新的版本中 <code>slaveof</code>已经替换为 <code>replicaof</code>，但是<code>slaveof</code>同样可以使用，并且作用是相同的，至于为什么可以通用，我从技术领域角度来说，闲的无聊，找点事做。</li>
<li><strong>个人建议在做主从复制时，一定要将master node做持久化操作，原因是当master node节点重启服务时，如果不做持久化的话，到时会将数据清空，同时slave node的数据也会被清空，导致不仅仅master数据丢失，slave node的数据也会丢失</strong></li>
<li>如果想实现部分重新同步，那么在redis4.x版本之后，需要将slave node也做持久化操作，至于原因会在下面的原理中给予解释</li>
</ol>
<h3 id="Redis复制的验证"><a href="#Redis复制的验证" class="headerlink" title="Redis复制的验证"></a>Redis复制的验证</h3><ol>
<li>开启rdis复制之后，我们可以在客户端中使用 <code>info replication</code>命令来查看是否已经开启复制成功<figure class="highlight bash"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br></pre></td><td class="code"><pre><span class="line"><span class="comment">## 主节点中 cli中执行 info replication</span></span><br><span class="line"><span class="comment"># Replication</span></span><br><span class="line">role:master</span><br><span class="line">connected_slaves:1</span><br><span class="line">slave0:ip=192.168.56.106,port=7000,state=online,offset=28,lag=0</span><br><span class="line"><span class="comment">## master node中的节点id</span></span><br><span class="line">master_replid:43db81ea472435516baa83e0164574bef8ac65f8</span><br><span class="line">master_replid2:0000000000000000000000000000000000000000</span><br><span class="line"><span class="comment">## master node中的节点偏移量</span></span><br><span class="line">master_repl_offset:28</span><br><span class="line">second_repl_offset:-1</span><br><span class="line">repl_backlog_active:1</span><br><span class="line">repl_backlog_size:1048576</span><br><span class="line">repl_backlog_first_byte_offset:1</span><br><span class="line">repl_backlog_histlen:28</span><br><span class="line"><span class="comment">## 子节点中 cli中执行 info replication</span></span><br><span class="line"><span class="comment"># Replication</span></span><br><span class="line">role:slave</span><br><span class="line">master_host:192.168.56.105</span><br><span class="line">master_port:7000</span><br><span class="line">master_link_status:up</span><br><span class="line">master_last_io_seconds_ago:5</span><br><span class="line">master_sync_in_progress:0</span><br><span class="line">slave_repl_offset:42</span><br><span class="line">slave_priority:100</span><br><span class="line">slave_read_only:1</span><br><span class="line">connected_slaves:0</span><br><span class="line">master_replid:43db81ea472435516baa83e0164574bef8ac65f8</span><br><span class="line">master_replid2:0000000000000000000000000000000000000000</span><br><span class="line">master_repl_offset:42</span><br><span class="line">second_repl_offset:-1</span><br><span class="line">repl_backlog_active:1</span><br><span class="line">repl_backlog_size:1048576</span><br><span class="line">repl_backlog_first_byte_offset:1</span><br><span class="line">repl_backlog_histlen:42</span><br></pre></td></tr></table></figure>
</li>
</ol>
<p>出现如上所述的master node 中 <code>connected_slaves:1</code>，说明master node存在一个连接的slave node节点，并且<code>slave0</code>是关于第一个子节点的配置信息。在slave node节点中<code>role</code>表明这个是子节点，并且<code>master_host</code>显示master node的IP信息，<code>master_link_status</code>表明是否连接上，up表示连接中，down表示连接失败，此处连接失败，可能是master node中<code>protected-mode</code>为yes导致。</p>
<h2 id="Redis主从复制的原理和核心机制"><a href="#Redis主从复制的原理和核心机制" class="headerlink" title="Redis主从复制的原理和核心机制"></a>Redis主从复制的原理和核心机制</h2><p>Redis主从复制的原理：</p>
<ol>
<li>slave node启动时，会向master node发送 sync命令。相当于向master node注册slave node的相关节点信息，让master node知道他存在一个子节点</li>
<li>slave node刚启动时，会发送<code>master_repl_offset</code>给master node，由master node决定是走完全重新同步还是部分重新同步步骤，如果<code>master_repl_offset</code>与master node是中的backlog中能找到，则是部分重新同步，否则是完全重新同步。</li>
<li>是完全重新同步：master node会将缓存所有的写入操作命令，同时fork一个子线程，生成RDB快照，master node将RDB文件传给slave node,slave node再将所有的命令同步到本地的内存中，如果此时slave node也做了持久化，则会将数据持久化到磁盘中</li>
<li>部分重新同步：不需要从master node中转存数据文件，master node直接将偏移量之后的所有命令同步发送给slave node节点，在slave node节点来完成数据的更新</li>
</ol>
<p>流程图如下：<br><img src="https://s2.ax1x.com/2019/06/17/VHR3ND.png" alt></p>
<p>为了更深层次的理解Redis是如何进行主从复制的，我们需要知道Redis复制的核心机制</p>
<ol>
<li>Redis采用异步方式复制数据到slave节点</li>
<li>一个master node 可以配置多个slave node</li>
<li>slave node之间可以互联互通，传递类似心跳的数据</li>
<li>slave node在做复制的时候，不会阻塞master node的正常工作</li>
<li>slave node在做复制的时候，也不会block对自己的查询操作，它会用旧的数据集来提供服务; 但是复制完成的时候，需要删除旧数据集，加载新数据集，这个时候就会暂停对外服务了</li>
<li>slave node主要用来进行横向扩容，做读写分离，扩容的slave node可以提高读的吞吐量</li>
</ol>
<h2 id="Redis主从复制调优"><a href="#Redis主从复制调优" class="headerlink" title="Redis主从复制调优"></a>Redis主从复制调优</h2><p>根据上面的主从复制的原理，我们可以知道主从复制进行的是完全重新同步还是部分重新同步的主要依据是<strong>slave提交给master的offset偏移量能否在master的replication backlog中查找到</strong>，如果能查找到则说明进行部分重新同步操作，如果查找不到则说明进行完全重新同步操作</p>
<p>再次之前我们先了解下 replication backlog是什么？<br>replication backlog是master中的环形缓冲区，该区域记录的是最新所有的写入命令，是一个固定长度的列表!</p>
<p>知道上述原理，我们可以通过控制backlog中的值的大小来控制是否进行完全重新同步还是部分重新同步，在redis.conf配置文件中backlog的大小是通过 <code>repl-backlog-size</code>来控制的，默认是1mb</p>
<p>在实际生产中，我们可以通过info replication中获取 <code>master_repl_offset</code> 的大小来估算backlog的大小</p>
<h2 id="Redis主从复制故障诊断"><a href="#Redis主从复制故障诊断" class="headerlink" title="Redis主从复制故障诊断"></a>Redis主从复制故障诊断</h2><p>影响Redis主从复制故障的原因可能有：磁盘IO、网络连接、数据集大小和长时间的阻塞等因素。</p>
<p>说起主从复制，我们需要先了解主从之间是怎么判断彼此之间的通讯，master想要知道slave是否正常运行，则会向slave发送ping命令，我们可以通过<code>repl-ping-replica-period</code>参数来调整这个间隔，默认间隔是10s</p>
<p>那么主从实例又是如何判断彼此之间复制链接被断开呢？</p>
<p>slave会向master发送REPLCONF ACK来报告他的复制偏移量，对Ping和REPLCONF ACK来说，都可以通过<code>repl-timeout</code>来指定超时时间，该值默认时间是60s，如果两次PING护着REPLCONF ACK之间的时间间隔比超时时间差，则可以认为主从复制链接被断开。</p>
<p>master向slave进行完全重新同步时，master会生成RDB快照文件，然后发送给slave,slave将RDB快照中的文件数据存储到slave的内存中，在这个步骤执行的过程中，如果master有新的数据写入，则master会将这部分数据写入到从客户端缓冲区（slave client buffer)中，在slaveRDB加载之后，将该缓冲区的数据发送给slave实例。但是这个实例是有大小限制的，当缓冲区的数据超过这个默认值时，则会导致复制重新开始。</p>
<p>所以我们在复制故障诊断时，需要注意参数<code>repl-ping-replication-period</code>和<code>repl-timeout</code>的值的控制，在生产环境中 <code>repl-ping-replication-period</code>一定要比<code>repl-timeout</code>小，否则容易造成复制超时。</p>
  </article>
  <aside class="table-content" id="site-toc">
  <div class="table-content-title">
    <i class="fa fa-arrow-right fa-lg" id="site-toc-hide-btn"></i>
    <span>目录</span>
  </div>
  <div class="table-content-main">
    <ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis的安装和持久化"><span class="toc-text">Redis的安装和持久化</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis的主从复制（replication"><span class="toc-text">Redis的主从复制（replication)</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#准备工作"><span class="toc-text">准备工作</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis主从复制"><span class="toc-text">Redis主从复制</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#Redis复制的启动"><span class="toc-text">Redis复制的启动</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis复制注意事项"><span class="toc-text">Redis复制注意事项</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#Redis复制的验证"><span class="toc-text">Redis复制的验证</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis主从复制的原理和核心机制"><span class="toc-text">Redis主从复制的原理和核心机制</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis主从复制调优"><span class="toc-text">Redis主从复制调优</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#Redis主从复制故障诊断"><span class="toc-text">Redis主从复制故障诊断</span></a></li></ol>
  </div>
</aside>
  
    <aside class="passage-copyright">
      <div>本文作者: Amos Zhu</div>
      
        <div>
          原文链接: 
          <a href target="_blank">http://amos_zhu.gitee.io/passages/Redis教程（三）——Redis的主从复制/</a>
        </div>
      
      <div>
        版权声明: 本博客所有文章除特别声明外, 均采用 <a href="https://creativecommons.org/licenses/by-nc-sa/4.0/">CC BY-NC-SA 4.0</a> 许可协议. 转载请注明出处!
      </div>
    </aside>
  
  
    <div class="passage-tags">
     
      <a href="/blog/tags/centos7/"><i class="fa fa-tags"></i>centos7</a>
     
      <a href="/blog/tags/redis/"><i class="fa fa-tags"></i>redis</a>
    
    </div>
  
</div>

    </main>
    
      
<div class="site-comment-contanier" data-plateform="leancloud">
  
    <p id="site-comment-info">
      <i class="fa fa-spinner fa-spin"></i> 评论加载中
    </p>
    <div id="site-comment"></div>
  
</div>
    
    <div class="site-footer-wrapper">
  <footer class="site-footer">
    
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">博客推荐</h5>
          
            <span class="site-footer-item">
              <a href="http://youzhixueyuan.com/series/java" target="_blank">优知学院</a>
            </span>
          
            <span class="site-footer-item">
              <a href="http://ruanyifeng.com/" target="_blank">阮一峰的个人网站</a>
            </span>
          
        </div>
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">系列教程</h5>
          
            <span class="site-footer-item">
              <a href="http://amos_zhu.gitee.io/blog/redis" target="_blank">Redis系列教程</a>
            </span>
          
            <span class="site-footer-item">
              <a href="http://amos_zhu.gitee.io/blog/rabbitMQ/" target="_blank">RabbitMQ教程</a>
            </span>
          
            <span class="site-footer-item">
              <a href="http://amos_zhu.gitee.io/blog/kafka/" target="_blank">Kafka架构探险</a>
            </span>
          
        </div>
      
        <div class="site-footer-col">
          <h5 class="site-footer-title">抓到我</h5>
          
            <span class="site-footer-item">
              <a href="https://gitee.com/amos_zhu" target="_blank">Gitee</a>
            </span>
          
            <span class="site-footer-item">
              <a href="https://blog.csdn.net/wdcl2468" target="_blank">CSDN</a>
            </span>
          
            <span class="site-footer-item">
              <a href="https://www.jianshu.com/u/2dbe61b1f3c3" target="_blank">简书</a>
            </span>
          
        </div>
      
    
    <div class="site-footer-info">
      <i class="fa fa-clock-o"></i> 本站已稳定运行<span id="site-time"></span>
    </div>
    
      <div class="site-footer-info">
        <i class="fa fa-paw"></i> 您是本站第 <span id="site-count"></span> 位访客
      </div>
    
    
      <div class="site-footer-info">
        <i class="fa fa-at"></i> Email: amoszhu@aliyun.com
      </div>
    
    <div class="site-footer-info">
      <i class="fa fa-copyright"></i> 
      2019 <a href="https://github.com/dongyuanxin/theme-ad/" target="_blank">Theme-AD</a>.
      Created by <a href="https://godbmw.com/" target="_blank">GodBMW</a>.
      All rights reserved.
    </div>
  </footer>
</div>
    <div id="site-layer" style="display:none;">
  <div class="site-layer-content">
    <div class="site-layer-header">
      <span class="site-layer-header-title" id="site-layer-title"></span>
      <i class="fa fa-close" id="site-layer-close"></i>
    </div>
    <div class="site-layer-body" id="site-layer-container">
      <div class="site-layer-input" id="site-layer-search" style="display: none;">
        <div class="site-layer-input-choose">
          <a href="javascript:void(0);" title="Change Search Engine">Google</a>
        </div>
        <input type="text">
        <i class="fa fa-search"></i>
      </div>
      
        <div class="site-layer-reward" id="site-layer-reward" style="display: none;">
          
            <div>
              <img src="/blog/images/wechat.png" alt="WeChat">
              
                <p>WeChat</p>
              
            </div>
          
            <div>
              <img src="/blog/images/alipay.png" alt="AliPay">
              
                <p>AliPay</p>
              
            </div>
          
        </div>
      
      <div id="site-layer-welcome" style="display:none;"></div>
    </div>
  </div>
</div>
    

<div class="bottom-bar">
  <div class="bottom-bar-left">
    <a href="/blog/passages/Redis教程（四）——配置高可用和集群/" data-enable="true">
      <i class="fa fa-arrow-left"></i>
    </a>
    <a href="/blog/passages/Redis教程（二）——Redis的持久化/" data-enable="true">
      <i class="fa fa-arrow-right"></i>
    </a>
  </div>
  <div class="bottom-bar-right">
    <a href="javascript:void(0);" data-enable="true" id="site-toc-show-btn">
      <i class="fa fa-bars"></i>
    </a>
    
      <a href="#site-comment" data-enable="true">
        <i class="fa fa-commenting"></i>
      </a>
    
    <a href="javascript:void(0);" id="site-toggle-share-btn">
      <i class="fa fa-share-alt"></i>
    </a>
    
      <a href="javascript:void(0);" id="site-reward">
        <i class="fa fa-thumbs-up"></i>
      </a>
    
    <a href="javascript:void(0);" id="back-top-btn">
      <i class="fa fa-chevron-up"></i>
    </a>
  </div>
</div>
    <div id="share-btn">
  
  
  
  
    <a id="share-btn-qq" href="javascript:void(0);" target="_blank">
      <i class="fa fa-qq"></i>
    </a>
  
  
    <a id="share-btn-wechat" href="javascript:void(0);" target="_blank">
      <i class="fa fa-wechat"></i>
    </a>
  
</div>
    


  <script async>
  (function(){
      var bp = document.createElement('script');
      var curProtocol = window.location.protocol.split(':')[0];
      if (curProtocol === 'https') {
          bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
      }
      else {
          bp.src = 'http://push.zhanzhang.baidu.com/push.js';
      }
      var s = document.getElementsByTagName("script")[0];
      s.parentNode.insertBefore(bp, s);
  })();
  </script>



  <script async>
    (function(){
    var src = (document.location.protocol == "http:") ? "http://js.passport.qihucdn.com/11.0.1.js?":"https://jspassport.ssl.qhimg.com/11.0.1.js?";
    document.write('<script src="' + src + '" id="sozz"><\/script>');
    })();
  </script>


    
  </body>
</html>